扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
1 ICMP协议协议概述
IP协议是一种不可靠的协议,无法进行差错控制。但IP协议可以借助其他协议来实现这一功能,如ICMP。
ICMP(Internet Control Messages Protocol, 网间控制报文协议)允许主机或路由器报告差错情况和提供有关异常情况的报告。
一般来说,ICMP报文提供针对网络层的错误诊断、拥塞控制、路径控制和查询服务四项大的功能。如,当一个分组无法到达目的站点或TTL超时后,路由器就会丢弃此分组,并向源站点返回一个目的站点不可到达的ICMP报文。
2 ICMP报文类型
2.1 ICMP报文类型
ICMP报文大体可以分为两种类型,即ICMP差错报文和ICMP询问报文。但细分又可分为很多类型,如表1所示。
表1 ICMP报文类型
2.2 ICMP回射请求和应答报文头部格式
ICMP报文被封装在IP数据报内部传输。如图1所示,是ICMP回射请求和应答报文头部格式。
图1 ICMP回射请求和应答报文头部格式
各种ICMP报文的前32bits都一样,它们是:
8bits类型和8bits代码字段:一起决定了ICMP报文的类型。常见的有:
类型8、代码0:回射请求。
类型0、代码0:回射应答。
类型11、代码0:超时。
16bits校验和字段:包括数据在内的整个ICMP数据包的校验和,其计算方法和IP头部校验和的计算方法是一样的。
对于ICMP回射请求和应答报文来说,接下来是16bits标识符字段:用于标识本ICMP进程。
最后是16bits序列号字段:用于判断回射应答数据报。
2.3 ICMP目标不可达报文
如图2所示,是ICMP目标不可达报文头部格式。
图2 ICMP目标不可达报文头部格式
其中代码字段的不同值又代表不同的含义,如,0代表网络不可达、1代表主机不可达等,见表1。
2.4 ICMP超时报文头部格式
如图3所示,是ICMP超时报文头部格式。
图3 ICMP超时报文头部格式
其中:
类型11+代码0:表示传输期间生存时间为0。
类型11+代码1:表示数据报组装期间生存时间为0。
由于篇幅有限,这里不再分析其他类型ICMP协议数据包的格式。
3 Ping命令
Ping命令利用ICMP回射请求报文和回射应答报文来测试目标系统是否可达。
ICMP回射请求和ICMP回射应答报文是配合工作的。当源主机向目标主机发送了ICMP回射请求数据包后,它期待着目标主机的回答。目标主机在收到一个ICMP回射请求数据包后,它会交换源、目的主机的地址,然后将收到的ICMP回射请求数据包中的数据部分原封不动地封装在自己的ICMP回射应答数据包中,然后发回给发送ICMP回射请求的一方。如果校验正确,发送者便认为目标主机的回射服务正常,也即物理连接畅通。
在Windows 9X、Windows 2000等操作系统的Ping命令中,ICMP包中的数据长度默认为32字节,其内容为英文小写字母循环系列(abcdefg…wabcdefghi),如图4所示。在Cisco路由器、交换机设备中,ICMP包的缺省内容模式是0xabcd,如图5所示。
图4 Windows下的PING包内容
图5 Cisco设备中的PING包内容
4 ICMP应用分析-ICMP重定向
ICMP虽然不是路由协议,但是有时它也可以指导数据包的流向(使数据流向正确的网关)。ICMP协议通过ICMP重定向数据包(类型5、代码0:网络重定向)达到这个目的。
图6 ICMP重定向
如图6所示,主机PC要ping路由器R2的loopback 0地址:192.168.3.1,主机将判断出目标属于不同的网段,因此它要将ICMP请求包发往自己的默认网关192.168.1.253(路由器R1的E0接口)。但是,这之前主机PC首先必须发送ARP请求,请求路由器R1的E0(192.168.1.253)的MAC地址。
当路由器R1收到此ARP请求包后,它首先用ARP应答包回答主机PC的ARP请求(通知主机PC:路由器R1自己的E0接口的MAC地址)。然后,它(路由器R1)将此ICMP请求转发到路由器R2的E0接口:192.168.1.254(要求路由器R1正确配置了到网络192.168.3.0/24的路由)。此外,路由器R1还要发送一个ICMP重定向消息给主机PC,通知主机PC对于主机PC请求的地址的网关是:192.168.1.254。
路由器R2此时会发送一个ARP请求消息请求主机PC的MAC地址,而主机PC会发送ARP应答消息给路由器R2。最后路由器R2通过获得的主机PC的MAC地址信息,将ICMP应答消息发送给主机PC。
ICMP重定向包的内容如图7、图8所示。注意图7 ICMP包头中的Type和Code字段的值和含义。
图7 ICMP重定向包
图8 ICMP重定向包-续
如果还有后续的ICMP请求包,则除了ARP消息,所有的事件序列和上面的叙述相同。如图9所示。
闂傚倸鍊峰ù鍥р枖閺囥垹绐楅柟鐗堟緲閸戠姴鈹戦悩瀹犲缂佺媭鍨堕弻锝夊箣閿濆憛鎾绘煛閸涱喗鍊愰柡宀嬬節瀹曟帒螣鐞涒€充壕闁哄稁鍋€閸嬫挸顫濋鍌溞ㄩ梺鍝勮閸旀垿骞冮姀銈呭窛濠电姴瀚槐鏇㈡⒒娴e憡璐¢柛蹇旓耿瀵劍娼忛埡鍐劸濡炪倖甯掔€氼參鎮¢妷鈺傜厽闁哄倹瀵ч崯鐐烘煟韫囷絽娅嶉柡宀€鍠愰ˇ鐗堟償閳ュ啿绠i梻浣芥〃閻掞箓骞戦崶褜鍤曟い鎺戝鍥撮梺绯曞墲椤ㄥ繑瀵奸幘鏂ユ斀妞ゆ梻銆嬪妤呮煕濡や礁鈻曠€殿噮鍋婇獮妯兼嫚閸欏妫熼梻渚€娼ч悧鍡椢涘Δ鍜佹晜闁割偅娲橀埛鎴︽偣閹帒濡奸柡瀣灴閺岋紕鈧綆浜堕悡鍏碱殽閻愯尙绠叉い锔惧閹棃顢欓悾宀€小闂傚倸鍊峰ù鍥р枖閺囥垹绐楅柟鎯у閻牊銇勯妷锔姐仢婵﹨娅i幑鍕Ω閵夛妇鈧箖姊洪崫鍕靛剰妞ゎ厾鍏橀悰顔跨疀濞戞瑥鈧鏌ら幁鎺戝姕婵炲懌鍨藉娲传閸曨偀鍋撻崼鏇炵9闁哄稁鍋€閸嬫挸顫濋鍌溞ㄩ梺鍝勮閸旀垿骞冮姀銈呭窛濠电姴瀚槐鏇㈡⒒娴e摜绉烘い銉︽崌瀹曟顫滈埀顒€顕i锕€绠荤紓浣贯缚閸欏嫰姊洪悷鏉挎Щ闁活厼鐗撳畷鐢碘偓锝庡枟閻撴瑧鈧懓瀚妯何f繝姘厵濞达絽鍟垮ú锕傛偂閵夆晜鐓熼柡鍐e亾婵$偛娼″畷鐢稿箣閿旂晫鍘甸梺鎼炲妽缁嬫垶绂嶆ィ鍐┾拻濞达綀濮ょ涵鍫曟煕閻樺啿濮嶇€殿喖鎲$换婵嗩潩椤掑偆鍞甸梻浣虹帛閸ㄥ吋鎱ㄩ妶澶婄柧闁归棿鐒﹂悡娑㈡煕鐏炰箙顏堝焵椤掍胶澧遍柍褜鍓氶懝鍓х礊婵犲洨宓佸〒姘e亾妞ゃ垺鐩幃娆戔偓娑櫳戦鐔兼⒒娴e憡鎯堥柛濠傜埣瀹曟劙寮介鐔蜂壕婵﹩鍓涚粔娲煛鐏炶濮傞柟顔哄灲瀹曘劍绻濋崟顏嗙?闂傚倷绀佸﹢閬嶅蓟婢跺ǹ鈧帡宕烽鐘辩瑝闂佺粯鍔楅崕銈夋偂閵夆晜鐓熼柡鍌涘閸熺偤鏌h箛锝呮珝闁哄瞼鍠愰ˇ鐗堟償閳ュ啿绠i梻浣芥〃閻掞箓骞戦崶褜鍤曟い鎺戝鍥撮梺绯曞墲椤ㄥ繑瀵奸幘缁樷拻濞达綀濮ょ涵鍫曟煕閻樺啿濮嶇€殿喖鎲$换婵嗩潩椤掑偆鍞甸梻浣虹帛閸ㄥ吋鎱ㄩ妶澶婄柧闁归棿鐒﹂悡娑㈡煕鐏炰箙顏堝焵椤掍胶澧遍柍褜鍓氶懝鍓х礊婵犲洤钃熼柕濞炬櫆閸嬪嫰鏌涘☉姗堝姛濞寸厧瀚板楦裤亹閹烘繃顥栭梺绋跨箲閿曘垹顕i锕€绠婚悹鍥у级椤ユ繈姊洪棃娑氬婵☆偅顨婇、鏃堝醇閺囩啿鎷洪柣鐘充航閸斿矂寮搁幋锔界厸閻庯綆浜堕悡鍏碱殽閻愯尙绠婚柟顔界矒閹崇偤濡烽敂绛嬩户缂傚倸鍊搁崐鐑芥嚄閸洖纾婚柣鏃傚帶杩濋柣搴秵閸犳牜绮婚鐐寸厽闁硅揪绲借闂佸搫鎳忛幃鍌炲蓟閿熺姴纾兼俊顖濄€€閸嬫捇寮介鐔蜂壕婵﹩鍓涚粔娲煛鐏炶濮傞柟顔哄灲瀹曘劍绻濋崟顏嗙?闂傚倷绀佺紞濠囁夐幘璇茬婵せ鍋撶€殿噮鍋婇獮妯兼嫚閸欏妫熼梻渚€娼ч悧鍡椢涘Δ鍜佹晜闁割偅娲橀埛鎴︽偣閹帒濡奸柡瀣灴閺岋紕鈧綆浜堕悡鍏碱殽閻愯尙绠婚柟顔界矒閹崇偤濡烽敂绛嬩户闂傚倷绀侀幖顐﹀磹閸洖纾归柡宥庡亐閸嬫挸顫濋鍌溞ㄩ梺鍝勮閸旀垿骞冮姀銈嗗亗閹艰揪绱曢梼鈧梻鍌欐祰椤宕曢幎钘夌疇闊洦娲嶉崑鎾愁潩椤掑倻楔闂佸搫琚崝鎴﹀箖閵忕妴铏圭磼濡粯鐝┑锛勫亼閸婃牠寮婚敓鐘茬柧婵炲棙鍨堕~鏇熴亜閺囨浜惧Δ鐘靛仜缁绘﹢骞冨⿰鍫熷殟闁靛闄勯鐔兼⒒娴h姤纭堕柛锝忕畵楠炲繘鏁撻敓锟�